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A METHOD AND S YSTEM FOR CONTROLLING ACCESS R Y CLIENTS TO 
SERVERS OVER AN INTERNET PROTOCOL NETWORK 

The present invention generally relates to a method and system for controlling access by 
clients to servers over an Internet Protocol network to which authorised persons can gain 
access. In particular the present invention relates to a method and system for 
authenticating Internet Protocol requests by clients for access to data at servers by 
performing authentication at the Internet Protocol level. 

The use of the Internet as a means of communicating electronically has become prolific. 
The protocol used by the Internet for communications is the Internet Protocol (a level 3 
protocol). The Internet Protocol is used as a protocol for carrying all of the types of 
protocols for providing the various services available over the Internet. For example, 
the Hyper Text Transfer Protocol (HTTP) is the protocol used for the World Wide Web. 
The File Transfer Protocol (FTP) is a commonly used protocol for the transfer of files 
over the Internet. The Simple Mail Transfer Protocol (SMTP) or the Post Office 
Protocol (POP) are the protocols used for the transfer of e-mails over the Internet. All 
of these protocols are carried by Internet Protocol packets using the Internet Protocol. 

In order for a data to be transferred using any one of these high level protocols, an 
Internet Protocol session must first be established. The schematic diagram of Figure 1 
and flow diagram of Figure 3 illustrate this process. An application such as a web 
browser, FTP client or e-mail application running on the Internet Protocol client 1 0 
generates an Internet Protocol request. The request provides an Internet Protocol data 
packet or packets as illustrated in Figure 2. The Internet Protocol data packet comprises 
a header section 1, a data pay load 2 and an error check code section 3. The data 2 
comprises a HTTP, FTP, SMTP or POP request or data. The header 1 carries 
information used for routing the Internet Protocol (IP) packet across the Internet. The 
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header 1 thus contains the destination and source IP address for the packet. When the IP 
request is generated by the IP client 1 0 it is generated to give the domain name of the 
destination server. The IP client 10 will direct the packet to an access server providing 
access to the Internet. The packet will then be directed to a domain name server (DNS) 
which will look up the IP address for the target server using the domain name. The IP 
address is typically a twelve digit number e.g. 124.121.121.156. 

With the IP address of the target server now determined the IP packet is routed over the 
Internet to the target IP server 20 (step Si). The IP server 20 responds by sending an IP 
acknowledgement to the IP address of the IP client 10 determined from the header 1 of 
the IP packet (step S2). When the IP client 10 receives the IP acknowledgement it 
returns an IP synchronisation acknowledgement to the IP server 20, (step S3). 

If the IP server 20 is provided with a firewall, it can look at the IP address of the IP 
client and authenticate the IP session on the basis of the IP address (step S4). If the IP 
address is a valid IP address, the session is authenticated and set up. The payload of the 
IP packet and subsequent packets can then be read by the IP server to perform the next 
level of authentication such as reading a user name and password carried by the higher 
level protocol e.g. HTTP. 

The problem with this prior art technique of authenticating access by a client to a server 
is that hackers can easily spoof the client's IP address as being an authentic IP address. 
Thus a hacker is able to set up a authenticated Transmission Control Protocol/Internet 
Protocol (TCP/IP) session. This has two disadvantages, namely: 

1) A server typically has a limited number of IP sessions that it can handle and a 
hacker can therefore overload the server. 

2) Relying upon the authentication technique of the high level protocols is less 
secure since typically for example for HTTP, CGI scripts have to be run on the Web 
server to process the data. These can have programme errors which a hacker can find 
their way around whilst the IP session is open. 
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It is thus an object of the present invention to provide a more secure authentication 
process for allowing access to a server by a client over an Internet Protocol network. 

The present invention thus provides a method and system in which an Internet Protocol 
request which is predestined for a target server is generated from a client apparatus and 
received at an intermediate security server. Upon receipt of the request the security 
server sends a request for authentication information to the client. If the client responds 
with authentication information the validation process is performed on the 
authentication information to authenticate the client or the user of the client. If the 
client or user is successfully authenticated, the Internet Protocol request from the client 
destined to a target server is transparently passed via the security server to the target 
server and data from the target server is returned to the client. 

If no authentication information is received within a predetermined period of time or the 
authentication process is unsuccessful, the security server returns a default response to 
the client. This default response can simply be a message that the requested data is not 
available or not accessible, or it can comprise default data such as a web page or 
instructions for a web browser to load a particular web page. This latter option is 
preferred for the implementation of the present invention as a web security server since 
it is not immediately apparent to a person trying to gain authorised access that they have 
been denied access to the target server. 

In one embodiment the process of requesting and receiving the authentication 
information comprises returning the IP acknowledgment signal from the security server 
client and receiving an IP acknowledgement from the client at the security server which 
includes an identifier identifying that the client may be authorised to access the target 
server. The client includes a particular functionality enabling it to modify the returned 
IP acknowledgement in a particular way which is recognisable by the security server. 
The security server then sends an IP request for the authentication information to the 
client and the client responds with an IP acknowledgement comprising an IP packet 
containing the authentication information. 
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In a preferred embodiment of the present invention the authentication process takes 
place on a remote secure server. The security server, when it receives the authentication 
information, passes this together with a validation request to the secure server. The 
secure server performs a validation check using the authentication information and 
returns a validation response to the security server which acts upon the response to 
either pass on the IP request from the client to the target server or return a default 
response to the client. 

In one embodiment the secure server includes a database of authorised users. The 
authentication information is compared to the database to determine whether the user is 
authorised. The database also includes a database of potential users. If the validation 
procedure is unsuccessful, the received authentication information is entered in the 
potential users database. This enables an administrator to access the database and 
transfer a user from the potential users database to the valid users database to enable the 
user to access the target server next time. This is particularly useful since it enables a 
user to make an initial attempt to access the target server and this is recorded at the 
secure server. An administrator can detect this first attempt and allow a user to access 
the target server subsequently by transferring the authentication information from the 
potential user's database to the valid user's database. 

In the present invention, public access can only be gained to the security server. The 
security server is thus preferably given an Internet Protocol address which is a class A or 
class B address. The secure server and the target server have class A Internet Protocol 
addresses which are only usable over local area networks thus preventing direct public 
access to these servers. 

In the embodiment of the present invention, the authentication information provided 
from the client can comprise information uniquely identifying the hardware and/or 
software configuration of the client machine, an electronically generated serial number, 
and a user name and password which have been entered by a user. 
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The present invention can be implemented by loading computer readable code on 
general purpose computers to provide the client and the server* Thus, the present 
invention encompasses computer programme code on a carrier medium such as a 
storage medium (e.g. floppy disk, magnetic tape, CD ROM, or programmable memory 
device), or a signal (e«g. an electrical signal carried over a network such as the Internet). 

In the present invention, the client and the server can comprise a computer programme 
implemented on a general purpose computer* It is thus possible for any combination of 
the target server, the secure server and the security server to reside on the same physical 
machine. It is however more preferable to provide these on separate physical machines 
to avoid any possibility of a hacker being able to bypass the secure means of 
communication between the service using the class C IP addresses in the specific 
embodiments. 

An embodiment of the present invention will now be described with reference to the 
accompanying drawings, in which: 

Figure 1 is a schematic diagram of a prior art Internet client and server authentication 
process, 

Figure 2 is a diagram of an IP packet, 

Figure 3 is a flow diagram illustrating the prior art IP session authentication process, 
Figure 4 is a schematic diagram of a system for provided secure access to a target server 
in accordance with an embodiment of the present invention, 

Figure 5 is a flow diagram illustrating the functions performed by the security server, 
Figure 6 is a flow diagram illustrating the functions performed by the client, 
Figure 7 is a schematic diagram of the functional components of the client, 
Figure 8 is a schematic diagram of functional code modules of the Internet protocol 
application in the client, 

Figure 9 is a schematic diagram of the functional code modules of the Internet protocol 
application in the security server, 
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Figure 10 is a flow diagram of the functions performed by the secure server, and 
Figure 1 1 is a flow diagram of the functions performed by the target server. 

The embodiment of the present invention will now be described with reference to 
Figures 4 to 11. 

An IP client is connected over an IP network such as the Internet to an IP security server 
40. The IP security server is connected via a local area network to a secure server 50 
which is provided with a database 60. The security 40 is also connected over a local 
area network to a target server 70. 

The security server 40 is connected to the Internet and is provided with a class A or B 
Internet address. This allows public access to the security server. The secure server 50 
and the target server 70 on the other hand are connected over an IP network (LAN) to 
the security server 40 and have a class C IP address, A class C IP address lies between a 
range 192.168.0.0 and 255.255,255.255. Such IP addresses are only usable locally. 

The operation of the security server 40 and the client will now be described in more 
detail with reference to the flow diagrams of Figures 5 and 6. In step S30 of Figure 6 
the client generates an IP request directed to the domain name given for the target 
server This is sent over the IP network to a domain name server (DNS) which looks up 
the IP address given for the target server. The domain name server is however given 
instead of the class C address for the target server, the class A or B address for the 
security server. In this way all IP traffic for a target server is directed to the security 
server rather than to the target server. Thus in step S10 of Figure 5 the security server 
receives the IP request from the client. In step S 1 1 an IP acknowledgement is sent to the 
IP address given in the header of the IP packet. In step S3 1 of Figure 6 the client 
receives the IP acknowledgement and in step S32 a flag is added to modify the header to 
indicate that the client has the capability to generate authentication information. The 
modified IP packet is then sent back in the received IP acknowledgement packet. This 
packet is received by the security server in step S12 and in step S 13 it is determined 
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whether the flag in the packet header is set. If not, this indicates that the IP packet has 
not come from a client which is capable of providing authentication information and 
thus in step S14 a default response is sent to the client. This response can comprise a 
message which will be displayed at the client indicating that no data is available or 
access has been denied to the data requested. 

If in step SI 3 the security server determines that the flag in the packet header has been 
set, in step SI 5 an IP request for a profile (authentication information) is sent to the 
client using the IP address obtained from the original IP request. The client waits in step 
S33 for a predetermined period for receipt of the IP request for the profile. If this 
request is not received within a predetermined period, in step S34 a default response is 
generated for display at the client. For example, a default web page can be generated 
and passed from the EP application in the client to the web browser for display of the 
default response. 

If in step 33 it is determined that an IP request is received within the predetermined 
period of time, optionally a window can then be displayed to allow a user to input a user 
name and password in (step S3 5). The client then wait input of the user name and 
password (step S36). As an alternative to requiring the input of the user name and 
password at this point, the user name and password could be input "offline" as soon as 
the IP application is loaded before the machine is switched on. 

At the client a profile is then generated using the input user name and password, unique 
identifying the hardware and/or software of the client machine such as the hard disk 
serial number, the Ethernet card serial number, the operating system serial number or 
the Bios serial number and an electronically generated serial number. The profile can be 
encrypted for additional security. 

The security server waits to receive a profile from the client within a predetermined 
period of time in step SI 6. If the profile is not received in the predetermined period of 
time, in step SI 4, the default response is sent to the client 
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If the profile is received within the predetermined period of time, in step S17 a 
validation request is sent to the secure server. The validation request carries the 
received profile and a request for authentication. The authentication process will be 
described in more detail hereinafter. The security server then receives a validation 
response from the secure server (step SI 8). If the validation response indicates that the 
profile is invalid (step SI 9) the security server sends a default response to the client 
(step Si 4). If the security server determines that the validation response indicates that 
the profile is valid (step SI 9), the initial IP request from the client is redirected by the 
security server to the target server (step S20). Thus in this process the security server 
simply acts as a router to modify the routing information in the header of the IP packet 
to pass the IP packet on to the target server. The target server then returns an IP 
acknowledgement to the security server (step S21) and the security server returns an IP 
sync acknowledgement to the target server (step S22) in the conventional authentication 
process. The IP session is thus established and in step S23 the data is received by the 
security server from the target server and this is sent to the client. 

At the client, in step S38 data is awaited within a predetermined period of time. If no 
data is received from the target server within the predetermined period of time, a default 
response is displayed (step S34). If data is received within the predetermined period of 
time (step S38) the data is displayed (step S39). This is the typical behaviour of a web 
browser. 



The functional structure of the client will now be described in more detail with reference 
to Figures 7 and 8. The client 30 can comprise any general purpose computer which 
will implement computer programme code. In this embodiment the application 
requiring data from the target server is a web browser 3 1 . Thus the protocol carried by 
the IP protocol is HTTP. Within the client 30 an IP application 32 monitors and 
modifies the flow of IP traffic between the web browser 3 1 and the IP network 
(Internet). Thus when the web browser generates the IP request this is passed by the IP 
application 32. When the IP acknowledgement is received it is also passed to the web 
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browser 3 1 . When the web browser acknowledgement response is output it is modified 
by the IP application 32 to include a flag to identify to the security server that there is an 
IP application 32 present on the client to generate and send a profile to allow 
authentication thus access to the target server. Thus when the security server responds 
with an IP request for the profile, this is received by the IP application 32 but not passed 
on to the web browser 31. The IP application 32 responds with an acknowledgement 
which carries a profile to the security server. 

Figure 8 is a functional diagram of the code provided in the IP application 32. The code 
to provide this functionality can be of any form or organisation. A user interface 33 is 
provided to enable a user to input a user name and password. A hardware reader 34 is 
provided to identify unique information about the hardware and/or software from the 
client machine such as the hard disk serial number, operating system serial number, 
BIOS serial number or any other information which uniquely identifies the 
configuration of the client machine. An electronic serial number generator 35 is also 
provided to generate an electronic serial number to further uniquely identify the client 
machine. A profile generator 37 receives the user name and password, the hardware and 
software information and the electronic serial number and uses this to generate a profile. 
The information can be encrypted within the generation of a profile. 

A stack monitor 36 is provided to monitor the protocol stack within the computer. The 
stack monitor 36 is able to modify the acknowledgement generated to the security server 
by the client to indicate that the stack monitor 36 is present. When the request is 
received from the security server for the profile, the stack monitor is able to intercept 
this request and prevent it being passed to the web browser 3 1. In response the stack 
monitor 36 inserts the profile generated by the profile generator 37 into an IP packet or 
packets and return this as the acknowledgement to the security server. 

The functional code structure of the security server will now be described in more detail 
with reference to Figure 9. The code to provide this functionality can be of any form or 
organisation. 
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Within the security server there is provided a stack monitor 41 to monitor the flow of IP 
traffic into and out of the security serve, When the stack monitor 41 detects a flag in an 
IP acknowledgement from a client, a profile request generator 45 can control the stack 
monitor 41 to request a profile from the client. When the profile is received, a 
validation request generator 44 can control the stack monitor 41 to send the profile 
together with the request for validation to the secure server 50. If no flag is set in the IP 
acknowledgement from the IP client, a profile is not received from the IP client, or the 
validation response from the secure server indicates the profile is invalid a default 
response generator 43 can generate a default response which is sent to the client The 
default response can either be a message or data. For example, the default response can 
comprise HTML for a web page, or simply a referral to another web site This will 
cause the web browser within the chent to display a web page, thus masking the fact that 
access has been denied to the target server. 

If the validation response from the secure server is positive, a redirection controller 42 
controls the stack monitor 41 to access the router to route the D> traffic between the 
client and the target server. 

The operation of the secure server will now be described in more detail with reference to 
the flow diagram of Figure 10. 

In step S40 a secure server receives a validation request from the security server The 
vahdation request carries the profile information and this is extracted from the request 
and decrypted where necessary. In step S41 the profile is used to look up in the valid 
user's database to determine whether the user is valid or not If the user is valid (step 
S42) the secure server responds with a "valid user" response (step S43). If it is 
determined that the user is not valid (step S42), in step S45 the secure server will 
respond with a "user invalid" response. The secure server will then determine whether 
the user is already listed in a potential user's database. If not the profile is added to the 
potential user's database in step S47. 
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The storage of profiles for users in a potential user's database means that a first time 
user to initially be denied access to the target server. An administrator of the secure 
server can however access the potential user's database and transfer the potential user to 
the valid user's database thus enabling the user to access the target server at the next 
attempt. It thus provides a very simple registration procedure under the control of the 
administrator. It also allows the user to select the usemame and password that they wish 
to use since this is the information that is entered in the profile which is initially entered 
in the potential user's database and then transferred to the valid user's database. 

The operation of the target server will now be described in more detail with reference to 
the flow diagram of Figure 1 1 . 

In step SSO the IP request originally from the client is received by the target server and 
in step S51 the target server generates an IP acknowledgement which is sent to the 
address in the IP packet header. In step S52 the security server responds with an 
acknowledgement which is received by the target server and thus in step S53 the IP 
session is open and the data carried by the IP packet is read and authenticated. Thus the 
target server is able to carry out further levels of authentication above the IP level 
protocol. For example, using HTTP, a CGI script could be run requiring the input of the 
user name and password for authentication to allow access to further web pages on the 
web site. This additional level of authentication which is conventional is provided on 
top of the IP protocol authentication provided by the present invention. 

Although the present invention has been described hereinabove with reference to a 
specific embodiment, it will be apparent to a skilled person in the art that modifications 
to the embodiment he within the spirit and scope of the present invention. 

Although in the embodiment the security server implementing the security application is 
described as lying physically on a separate machine to the target server, it is however 
possible for the two server applications to be implemented on a single physical machine. 
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In such a case the security server and target server have the same IP address but will be 
given different ports. 

It is also possible to incorporate the secure server in a single physical machine carrying 
the security server and/or the target server. In this case once again the secure server can 
be distinguished and communicated with using a different port. It is however preferabl 
in the present invention to use separate physical machines to avoid the possibility that a 
hacker can bypass the security server to directly access the target server or the secure 
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server. 



In the embodiment of the present invention described hereinabove the profile obtained 
from the client machine uniquely identifies the machine (it comprises a hardware and 
software signature of the machine and user). The present invention encompasses any 
authentication information which enables the client machine or user to be uniquely 
identified. 

Although in the embodiment described hereinabove in the IP network is described as 
comprising the Internet, the present invention can comprise any IP network such as an 
extranet or intranet. 

It will be apparent to the person skilled in the art that the servers described in the 
embodiment of the present invention can comprise computer applications and can thus 
be embodied as software provided to a general purpose computer on any suitable 
medium such as a storage medium e.g. floppy disk drive, hard disk drive, CD ROM 
signal such as an electronic signal carried over the Internet. 



earner 
or a 



The security server acts as an intermediate server between the client and the target 
server. Because the security server contains no data which is accessible by the client, 
security is ensured. The physical separation of the secure server ensures that sensitive 
information enabling access to the target server is remote from the security server thus 
preventing access to the information by a hacker. 
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